nats -> adx1(zeros)
zeros -> cons2(0, zeros)
incr1(cons2(X, Y)) -> cons2(s1(X), incr1(Y))
adx1(cons2(X, Y)) -> incr1(cons2(X, adx1(Y)))
hd1(cons2(X, Y)) -> X
tl1(cons2(X, Y)) -> Y
↳ QTRS
↳ DependencyPairsProof
nats -> adx1(zeros)
zeros -> cons2(0, zeros)
incr1(cons2(X, Y)) -> cons2(s1(X), incr1(Y))
adx1(cons2(X, Y)) -> incr1(cons2(X, adx1(Y)))
hd1(cons2(X, Y)) -> X
tl1(cons2(X, Y)) -> Y
ADX1(cons2(X, Y)) -> ADX1(Y)
ADX1(cons2(X, Y)) -> INCR1(cons2(X, adx1(Y)))
NATS -> ADX1(zeros)
NATS -> ZEROS
ZEROS -> ZEROS
INCR1(cons2(X, Y)) -> INCR1(Y)
nats -> adx1(zeros)
zeros -> cons2(0, zeros)
incr1(cons2(X, Y)) -> cons2(s1(X), incr1(Y))
adx1(cons2(X, Y)) -> incr1(cons2(X, adx1(Y)))
hd1(cons2(X, Y)) -> X
tl1(cons2(X, Y)) -> Y
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
ADX1(cons2(X, Y)) -> ADX1(Y)
ADX1(cons2(X, Y)) -> INCR1(cons2(X, adx1(Y)))
NATS -> ADX1(zeros)
NATS -> ZEROS
ZEROS -> ZEROS
INCR1(cons2(X, Y)) -> INCR1(Y)
nats -> adx1(zeros)
zeros -> cons2(0, zeros)
incr1(cons2(X, Y)) -> cons2(s1(X), incr1(Y))
adx1(cons2(X, Y)) -> incr1(cons2(X, adx1(Y)))
hd1(cons2(X, Y)) -> X
tl1(cons2(X, Y)) -> Y
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDPOrderProof
↳ QDP
↳ QDP
INCR1(cons2(X, Y)) -> INCR1(Y)
nats -> adx1(zeros)
zeros -> cons2(0, zeros)
incr1(cons2(X, Y)) -> cons2(s1(X), incr1(Y))
adx1(cons2(X, Y)) -> incr1(cons2(X, adx1(Y)))
hd1(cons2(X, Y)) -> X
tl1(cons2(X, Y)) -> Y
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
INCR1(cons2(X, Y)) -> INCR1(Y)
POL( cons2(x1, x2) ) = x2 + 1
POL( INCR1(x1) ) = x1
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDPOrderProof
↳ QDP
↳ PisEmptyProof
↳ QDP
↳ QDP
nats -> adx1(zeros)
zeros -> cons2(0, zeros)
incr1(cons2(X, Y)) -> cons2(s1(X), incr1(Y))
adx1(cons2(X, Y)) -> incr1(cons2(X, adx1(Y)))
hd1(cons2(X, Y)) -> X
tl1(cons2(X, Y)) -> Y
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDPOrderProof
↳ QDP
ADX1(cons2(X, Y)) -> ADX1(Y)
nats -> adx1(zeros)
zeros -> cons2(0, zeros)
incr1(cons2(X, Y)) -> cons2(s1(X), incr1(Y))
adx1(cons2(X, Y)) -> incr1(cons2(X, adx1(Y)))
hd1(cons2(X, Y)) -> X
tl1(cons2(X, Y)) -> Y
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
ADX1(cons2(X, Y)) -> ADX1(Y)
POL( cons2(x1, x2) ) = x2 + 1
POL( ADX1(x1) ) = x1
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDPOrderProof
↳ QDP
↳ PisEmptyProof
↳ QDP
nats -> adx1(zeros)
zeros -> cons2(0, zeros)
incr1(cons2(X, Y)) -> cons2(s1(X), incr1(Y))
adx1(cons2(X, Y)) -> incr1(cons2(X, adx1(Y)))
hd1(cons2(X, Y)) -> X
tl1(cons2(X, Y)) -> Y
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
ZEROS -> ZEROS
nats -> adx1(zeros)
zeros -> cons2(0, zeros)
incr1(cons2(X, Y)) -> cons2(s1(X), incr1(Y))
adx1(cons2(X, Y)) -> incr1(cons2(X, adx1(Y)))
hd1(cons2(X, Y)) -> X
tl1(cons2(X, Y)) -> Y